草庐IT

c++ - 影响 Makefile 中其他库的库

全部标签

c - 如何在没有定义 main() 的情况下让 cgo 构建目标文件?

我有一个完全用C编写的项目。我只需要调用一个必须用GO编写的函数。因此,我使用cgo构建C文件,然后我想使用生成的目标文件与我的主C项目链接。假设我有一个文件foo.go和一个函数funcHelloWorld()。我希望从我的C代码中执行此函数。所以我做了以下步骤#gotoolcgofoo.go#cd_obj&&gcc-c*.o现在我有两个文件:#_cgo_export.o_cgo_main.o但是,main()以某种方式在那里定义,我无法将这些目标文件与我的主项目(多个主项目)链接。我如何让cgo不放入虚拟main?还是我这样做完全错了?编辑我需要入口点在C中。其他人发布的建议要求入

objective-c - cgo godefs 和 Objective-C

我通过CGoLang的包在GoLang上编写了一个包含Objective-C代码(调用一些OSXAPI)的程序,我需要从Go传递类型为T的变量代码到Objective-C代码,反之亦然。T是结构(或其他类型)。所以我需要在GoLang中创建兼容的(在内存布局方面)类型/变量,并通过unsafe.Pointer转换将其传递给Objective-C。对于通用C代码,我在这种情况下使用godefs,但我无法将godefs用于Objective-C。如果我尝试gotoolcgo-godefscgodefs.go//Thisis"cgodefs.go"filepackagetmp/*#cgoCF

go - 使用 gorilla 多路复用器路由器时如何忽略一个词并匹配所有其他词?

例如,我有一个处理“/items/{item-id}”的函数和另一个处理“/items/request-task”的函数。如何让第一个函数忽略“/items/request-task”并匹配其余的? 最佳答案 像这样。packagemainimport("net/http""github.com/gorilla/mux")funcmain(){r:=mux.NewRouter()r.HandleFunc("/items/request-task",func(whttp.ResponseWriter,r*http.Request){w

c - 将 cgo 与 typedef 变量一起使用

由于现有的库和速度,我正在创建一个项目,该项目使用我用C编写的密码学。尝试与Cgo交互时,我在使用C中创建的typedef时遇到了一些问题。下面是一个示例:typedefunsignedcharec_scalar[32];我能够成功创建ec_point变量,并使用接受ec_point*的函数。但是,每当我尝试使用通过普通ec_point传递的函数时,我都会收到错误消息:cannotusepk2(typeC.ec_scalar)astype*C.ucharinargumentto_Cfunc_secret_to_public我似乎找不到可以轻松转换它的方法。我也不想重构我的代码来接受ec

c - 将 C 翻译成 Golang。如何分配内存以匹配 C?

所以我正在翻译我在C中创建的程序。这个程序的目标是简单地从文件中读取矩阵,以稀疏行格式压缩矩阵,然后计算矩阵vector乘积。这是C语言的程序片段。//ReadtheMatrixMarketfileandinitializeaCSRformattedmatrix.csr_load_matrix(fileName,&compressedSparseMatrix);//Setthecorrectvaluestothestructandcreatethememoryallocation.double*x;double*y;x=malloc(compressedSparseMatrix.col

bash - 如何从其他目录执行go get?

我正在编写一个别名(unix),它将更新一个git存储库,然后调用goget-d./...(加载所有依赖项)。有没有办法在git中调用类似的东西(如下)?git-C/my/path/with/git/repopulloriginmaster简而言之,有没有办法将命令的上下文目录传递给goget? 最佳答案 只需在别名中的goget之前添加一个cd逗号即可:aliasx="(cd/path/to/repo;goget-d./...)"不要忘记括号,否则您将不得不cd回到原始目录。 关于ba

docker - 从一个 Dockerized Go 服务获取查询到其他 Dockerized Go 服务

我在Go中构建了一些服务,我可以使用docker-compose部署它们。我还链接了服务,但现在如果我从一个应用程序向另一个应用程序发出GET请求,我会得到不支持的协议(protocol)方案。这是因为我在URL中使用服务名称而没有指定任何协议(protocol)。链接和查询适用于mongoDB,但不适用于其他服务。去service1文件url:="service2/get"//thisisnotworkingresponse,err:=http.Get(url)iferr!=nil{fmt.Printf("%s",err)}else{//dosomething}Docker-comp

c - 在 libpango 中调用 pango_cairo_font_map_get_default() 时出现 "GLib-GObject-CRITICAL"的原因是什么?

这是一道关于gtk/glib/libpango/libcairo的概念题。让我们直奔问题。我正在用一位前同事用Go编写的旧C库进行包装,在C代码调用的某处pango_cairo_font_map_get_default()获取由libpango维护的默认font_map。包装基本上是从Go域进入C域(外部函数接口(interface))和C端使用pthread创建一个线程最终调用pango_cairo_font_map_get_default。最初,在纯C端一切正常。包装后,C代码卡在调用pango_cairo_font_map_get_default()printf("beforec

c - 通过Cgo访问aerospike C客户端报错

我正在尝试学习Cgo,所以我尝试从Cgo访问aerospike客户端packagemain//#cgoCFLAGS:-g-Wall//#include//#include//#include"aerospike-client-c/examples/put/example_utils.h"import"C"import("unsafe")funcmain(){retvals:=C.putitnew()_=retvals}但我遇到以下错误。(请注意,当我执行make和makerun时,C程序运行成功)。undefinedreferenceto`example_get_opts'./aero

Makefile基础教程

前期准备在真正使用Makefile之前,我们首先先写四个c文件和相应的h文件,分别是fun0.c,fun1.c,fun2.c,fun0.h,fun1.h,fun2.h以及main.c//fun0.c#include"fun0.h"voidprint0(){ printf("helloworld0");}//fun0.h#includevoidprint0(void);//fun1.c#include"fun1.h"voidprint1(){ printf("helloworld1");}//fun1.h#includevoidprint1(void);//fun2.c#include"fun2